



# Design of a Microprocessor

The uP3207 processor



### Operation of a Simple Microprocessor



- Program to be executed is stored in memory
- Instruction Fetch Unit of CPU will fetch an instruction at a time from memory
- Instruction is sent to the decoding and sequencing unit (DSU)
- The DSC is a state machine that creates the sequence of actions to execute the instruction
  - The sequence acts on objects such the ALU, registers and I/O devices
- Once done control is reverted to the Instruction Fetch Unit to fetch the next instruction.



#### The uP3207 processor

Our First Central Processing Unit

- What to design?
  - Requirement analysis on intended application
  - Not to be addressed in this course. Assume this is done.

#### Features

- 16 bit data width processor
- 4K words addressable memory
- Stack for temporary variable storage
- Single word instructions
  - Single operands architecture
- Support direct and indirect addressing
- Support multiple interrupts from input and output devices
- Low cost
- Complete functionalities



## uP3207 Microprocessor



#### ISA: Registers and memory overview

- PC: program counter
  - Holds address of the next instruction
- SP: stack pointer
- BP: base pointer
- AC: accumulator
  - main processor register
- XR: operand register
  - For holding the operand of arithmetic/logic operations
- Flags
  - S=AC negative
  - Z=AC zero
  - C=carry flag set
  - Y=DR=o

#### **Programmer's View**





#### ISA: instructions

- Memory reference group
  - Bits 12-14 not all ones => memory access and Bits 0-11 are addresses
    - I=1 implies indirect addressing
    - I=o implies direct addressing
    - total of 7 memory instructions (from ooo to 110)
- Non-memory reference group
  - Bit 12-14 are ones, ops are internal => no need for address. Therefore the Bits o-11 are used to indicate other instructions



## Addressing modes

- direct
  - bits o 11 is the address of the operand
- indirect
  - bits o 11 is the address in which we obtain the address of the operand
    - bit 15 can be used to indicate the addressing mode
  - BP indirect
- Immediate (not directly supported)
  - data is placed at a designated location in memory. It can then be loaded using direct or indirect addressing method.



(a) Instruction format



(b) Direct address



(c) Indirect address

#### Definition of Instructions:

#### Memory reference instructions

|        | Hexadecim | al code |                                               |
|--------|-----------|---------|-----------------------------------------------|
| Symbol | I = 0     | I = 1   | Description                                   |
| LDB    | 0xxx      | 8xxx    | Load memory word to BP                        |
| LDX    | 1xxx      | 9xxx    | Load memory word to XR                        |
| LDA    | 2xxx      | Axxx    | Load memory word to AC                        |
| STA    | 3xxx      | Bxxx    | Store content of AC in memory                 |
| BUN    | 4xxx      | Cxxx    | Branch unconditionally                        |
| CALL   | 5xxx      | Dxxx    | Push PC onto stack and branch unconditionally |
| DSZ    | 6xxx      | Exxx    | Decrement and skip if zero                    |

| • 4 🗉      | 4 •   |
|------------|-------|
| arithn     | 1etic |
| tti itiiii |       |
|            |       |

# Register reference instructions

logic

**Shift** 

Bit manipulation

Subroutine /stack

Conditional branch

|   | INC   | 7010 | Increment AC                               |
|---|-------|------|--------------------------------------------|
|   | DEC   | 7011 | Decrement AC                               |
|   | ADD   | 7012 | AC=AC+XR                                   |
|   | ADC   | 7013 | AC=AC+XR+C                                 |
|   | SUB   | 7014 | AC=AC-XR                                   |
|   | SBB   | 7015 | AC=AC-XR+1                                 |
|   | AND   | 7016 | AC=AC and XR                               |
|   | OR    | 7017 | AC=AC or XR                                |
| / | XOR   | 7020 | AC=AC xor XR                               |
|   | SHR   | 7021 | Shift AC right                             |
| / | SHL   | 7022 | Shift AC left                              |
|   | CLAC  | 7023 | Clear AC                                   |
|   | CMAC  | 7024 | Complement AC                              |
| / | CLC   | 7025 | Clear C                                    |
|   | CMC   | 7026 | Complement C                               |
|   | STC   | 7027 | Set C                                      |
|   | AC2SP | 7040 | Move content of AC to SP                   |
|   | SP2BP | 7041 | Move content of SP to BP                   |
|   | LDABP | 7042 | Load AC indirect through BP                |
| / | IRET  | 7043 | Restore address from stack onto PC and ION |
|   | RET   | 7044 | Restore address from stack onto PC         |
|   | POP   | 7045 | Pop word from the stack onto AC            |
|   | PUSH  | 7046 | Push AC onto the stack                     |
|   | SZAC  | 7047 | Skip next instruction if AC zero           |
|   | SNAC  | 7080 | Skip next instruction if AC negative       |
|   | SPAC  | 7081 | Skip next instruction if AC positive       |
|   | SSC   | 7082 | Skip next instruction if C is set          |
|   | SCC   | 7083 | Skip next instruction if C is clear        |
|   | ION   | 7084 | Interrupt on                               |
|   | IOF   | 7085 | Interrupt off                              |
|   |       |      |                                            |

### Instruction set completeness

- Arithmetic
  - add, adc, sub, sbb, inc, dec
  - Instructions like multiple can be synthesized in software
- Logical
  - and, or, not, xor
    - AND and NOT gives NAND => all logic operations can be performed
- Shift instructions
  - shr, shl
- Instructions for moving information to from memory and processor registers
  - lda, sta
- Program control instructions together with instructions that check status condition.
  - bun, call, dsz. 4 skip instructions
- Input and output instructions.
  - I/O devices are memory mapped

## Design of the CPU

The bus

The state generator

Actions in each state for each instruction

#### Common bus concept for transfer of memory content

- Using digital multiplexer
  - intuitive but not normally used in uP design
  - instead we have transtate buffer
    - beside o and 1, there is a third high impedanc state
    - allows many devices to be electrically tied together as lon as only one device asserts a o or 1 at any on time



#### Construction of a bus system:

#### another perspective

• Bus line with three states buffers Normal input A



Output Y=A if C=1 High impedance if C=0

- outputs requires tri-states buffers Control input C
- inputs connected directly to inputs of registers
  - enable to load values
  - check fanout requirement



#### ISA: Registers and memory overview

- PC: program counter
  - Holds address of the next instruction
- AR: address register
  - holds address for selecting memory
- SP: stack pointer
- BP: base pointer
- IR: instruction register
  - holds the instruction code for decoding
- TR: temporary register
- DR: data register
  - holds memory operand
- AC: accumulator
  - main processor register
- XR: operand register
  - For holding the operand of arithmetic/logic operations
- Flags
  - S=AC negative
  - Z=AC zero
  - C=carry flag set
  - Y=DR=o

What are the objects in the system? What are available to the programmer?



## Common bus system of uP4202

- 11 items
  - internal bus to control the movement of data among them
  - 4 bit control lines to determine who drives bus
  - LD line to load specific register
  - the specific word location in the 4K memory is selected by AR

#### Control

• We need to generate So-S<sub>3</sub>, LD, INR, CLR to control the movement of data around at the appropriate time.



## Timing and control

 Creation of sequencing control in the decoding of instructions





Instruction cycle

- Fetch an instruction from memory
- Decode instruction
- Read the effective address from if the instruction has an indirect address
- execute the instruction

An instruction always start with T0, then T1, ....

During states T0 and T1, instruction is fetched.

How to fetch an instruction?





#### During State T2:

- **DECODE.** Set
  - D7←1 if opcode =111
  - $I \leftarrow IR(15)$
  - AR  $\leftarrow$  IR(o-11)





#### Memory reference instructions

- Do to D6 determine each one of the below instruction
- from flowchart effective address placed during T2 or T3 depending on whether direct or indirect addressing

| LDB  | 0XXX 8XXX | $D_0T_4$                                                                                                                              | $BP \leftarrow M[AR], SC \leftarrow 0$                                                                                                           | Bus transfer                                                                                          |
|------|-----------|---------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|
| LDX  | 1XXX 9XXX | $D_1T_4$                                                                                                                              | $XR \leftarrow M[AR], SC \leftarrow 0$                                                                                                           | Bus transfer                                                                                          |
| LDA  | 2XXX AXXX | $\begin{array}{c} D_2T_4 \\ D_2T_5 \end{array}$                                                                                       | $DR \leftarrow M[AR], AC \leftarrow 0$<br>$AC \leftarrow AC + DR, SC \leftarrow 0$                                                               | Note that input to AC is connected to ALU, not bus.                                                   |
| STA  | 3XXX BXXX | $D_3T_4$                                                                                                                              | $M[AR] \leftarrow AC, SC \leftarrow 0$                                                                                                           | Bus transfer                                                                                          |
| BUN  | 4XXX CXXX | $D_4T_4$                                                                                                                              | $PC \leftarrow AR, SC \leftarrow 0$                                                                                                              | Branch address already in AR by T <sub>3</sub>                                                        |
| CALL | 5XXX DXXX | $\begin{array}{c} D_5 T_4 \\ D_5 T_5 \\ D_5 T_6 \\ D_5 T_7 \end{array}$                                                               | $SP \leftarrow SP-1, TR \leftarrow AR$<br>$AR \leftarrow SP$<br>$M[AR] \leftarrow PC$<br>$PC \leftarrow TR, SC \leftarrow 0$                     | Store in TR the branch address that is in AR. Store current PC on stack. Transfer TR to PC to branch. |
| DSZ  | 6XXX EXXX | D <sub>6</sub> T <sub>4</sub><br>D <sub>6</sub> T <sub>5</sub><br>D <sub>6</sub> T <sub>6</sub> Y<br>D <sub>6</sub> T <sub>6</sub> Y' | $DR \leftarrow M[AR]$ $DR \leftarrow DR - 1$ $M[AR] \leftarrow DR, PC \leftarrow PC + 1, SC \leftarrow 0$ $M[AR] \leftarrow DR, SC \leftarrow 0$ | Read in data to DR.<br>Check for zero to branch                                                       |

#### Register reference instruction in T3

Use a 3-8 decoder

|     |      |                                                                                                                                  | $D_{7}I' T_{3} = r$ $IR(i) = Bi (i=0 \text{ TO } 11)$ $K_{0} = B_{2}'B_{1}'B_{0}', K_{1} = B_{2}'B_{1}'B_{0},, K_{7} = B_{2}B_{1}B_{0},$ |                |
|-----|------|----------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|----------------|
|     |      | r                                                                                                                                | $SC \leftarrow 0$                                                                                                                        |                |
| INC | 7010 | $rB_4K_0$                                                                                                                        | $AC \leftarrow AC + 1, SC \leftarrow 0$                                                                                                  | Increment AC   |
| DEC | 7011 | rB <sub>4</sub> K <sub>1</sub>                                                                                                   | $AC \leftarrow AC-1, SC \leftarrow 0$                                                                                                    | Decrement AC   |
| ADD | 7012 | D <sub>7</sub> I' T <sub>3</sub> B <sub>4</sub> K <sub>2</sub><br>D <sub>7</sub> I' T <sub>4</sub> B <sub>4</sub> K <sub>2</sub> | $   \begin{array}{c}     DR \leftarrow XR \\     AC \leftarrow AC + DR, SC \leftarrow 0   \end{array} $                                  | AC=AC+XR       |
| ADC | 7013 | D <sub>7</sub> I' T <sub>3</sub> B <sub>4</sub> K <sub>3</sub><br>D <sub>7</sub> I' T <sub>4</sub> B <sub>4</sub> K <sub>3</sub> | $DR \leftarrow XR$ $AC \leftarrow AC + DR + C, SC \leftarrow 0$                                                                          | AC=AC+XR+C     |
| SUB | 7014 | D <sub>7</sub> I' T <sub>3</sub> B <sub>4</sub> K <sub>4</sub><br>D <sub>7</sub> I' T <sub>4</sub> B <sub>4</sub> K <sub>4</sub> | $   \begin{array}{c}     DR \leftarrow XR \\     AC \leftarrow AC - DR, SC \leftarrow 0   \end{array} $                                  | AC=AC-XR       |
| SBB | 7015 | D <sub>7</sub> I' T <sub>3</sub> B <sub>4</sub> K <sub>5</sub><br>D <sub>7</sub> I' T <sub>4</sub> B <sub>4</sub> K <sub>5</sub> | $DR \leftarrow XR$ $AC \leftarrow AC - DR + C, SC \leftarrow 0$                                                                          | AC=AC-XR+1     |
| AND | 7016 | D <sub>7</sub> I' T <sub>3</sub> B <sub>4</sub> K <sub>6</sub><br>D <sub>7</sub> I' T <sub>4</sub> B <sub>4</sub> K <sub>6</sub> | $DR \leftarrow XR$ $AC \leftarrow AC \land DR, SC \leftarrow 0$                                                                          | AC=AC and XR   |
| OR  | 7017 | D <sub>7</sub> I' T <sub>3</sub> B <sub>4</sub> K <sub>7</sub><br>D <sub>7</sub> I' T <sub>4</sub> B <sub>4</sub> K <sub>7</sub> | $DR \leftarrow XR$ $AC \leftarrow AC \lor DR, SC \leftarrow 0$                                                                           | AC=AC or XR    |
| XOR | 7020 | $D_7I' T_3 B_5K_0  D_7I' T_4 B_5K_0$                                                                                             | $DR \leftarrow XR$ $AC \leftarrow AC \oplus DR, SC \leftarrow 0$                                                                         | AC=AC xor XR   |
| SHR | 7021 | rB <sub>5</sub> K <sub>1</sub>                                                                                                   | $AC \leftarrow \text{shr } AC, AC(15) \leftarrow E, E \leftarrow AC(0), SC \leftarrow 0$                                                 | Shift AC right |
| SHL | 7022 | rB <sub>5</sub> K <sub>2</sub>                                                                                                   | $AC \leftarrow \text{shl AC}, AC(0) \leftarrow E, E \leftarrow AC(15), SC \leftarrow 0$                                                  | Shift AC left  |

#### Register reference instruction in T3

| CLAC  | 7023 | $rB_5K_3$                                                                                                       | $AC \leftarrow 0$ , $SC \leftarrow 0$                                                              | Clear AC                    |
|-------|------|-----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|-----------------------------|
| CMAC  | 7024 | rB <sub>5</sub> K <sub>4</sub>                                                                                  | $AC \leftarrow AC', SC \leftarrow 0$                                                               | Complement AC               |
| CLC   | 7025 | rB <sub>5</sub> K <sub>5</sub>                                                                                  | $C \leftarrow 0$ , $SC \leftarrow 0$                                                               | Clear C                     |
| CMC   | 7026 | rB <sub>8</sub> K <sub>6</sub>                                                                                  | $C \leftarrow C', SC \leftarrow 0$                                                                 | Complement C                |
| STC   | 7027 | rB <sub>5</sub> K <sub>7</sub>                                                                                  | $C \leftarrow 1$ , $SC \leftarrow 0$                                                               | Set C                       |
| AC2SP | 7040 | $rB_6K_0$                                                                                                       | $SP \leftarrow AC, SC \leftarrow 0$                                                                | Move content of AC to SP    |
| SP2BP | 7041 | rB <sub>6</sub> K <sub>1</sub>                                                                                  | $BP \leftarrow SP, SC \leftarrow 0$                                                                | Move content of SP to BP    |
| LDABP | 7042 | $\begin{array}{c} D_{7}I' T_{3} B_{6}K_{2} \\ D_{7}I' T_{4} B_{6}K_{2} \\ D_{7}I' T_{5} B_{6}K_{2} \end{array}$ | $AR \leftarrow BP, AC \leftarrow 0$ $DR \leftarrow M[AR]$ $AC \leftarrow AC + DR, SC \leftarrow 0$ | Load AC indirect through BP |

## Register reference instruction in T3

| IRET                                                | 7043 | $D_7I'T_3B_6K_3$                    | AR ← SP                                                      | Restore address from stack onto     |
|-----------------------------------------------------|------|-------------------------------------|--------------------------------------------------------------|-------------------------------------|
|                                                     |      | $D_7I'T_4B_6K_3$                    | $PC \leftarrow M[AR], SP \leftarrow SP + 1$                  | PC and ION                          |
|                                                     |      | $D_7I'T_5B_6K_3$                    | AR ←SP                                                       |                                     |
|                                                     |      | $D_7I'T_6B_6K_3$                    | $FLAGS \leftarrow M[AR], SP \leftarrow SP + 1, IEN$          |                                     |
|                                                     |      |                                     | $\leftarrow 1, SC \leftarrow 0$                              |                                     |
| RET                                                 | 7044 | $D_7I'T_3B_6K_4$                    | AR ← SP                                                      | Restore address from stack onto     |
|                                                     |      | $D_7I'T_4B_6K_4$                    | $PC \leftarrow M[AR], SP \leftarrow SP + 1, SC \leftarrow 0$ | PC                                  |
| POP                                                 | 7045 | $D_7I'T_3B_6K_5$                    | $AR \leftarrow SP, AC \leftarrow 0$                          | Pop word from the stack onto AC     |
|                                                     |      | $D_7I'T_4B_6K_5$                    | $DR \leftarrow M[AR], SP \leftarrow SP + 1$                  |                                     |
| v nanananananan<br>v nanananananan<br>v nananananan |      |                                     | $AC \leftarrow AC + DR, SC \leftarrow 0$                     |                                     |
| PUSH                                                | 7046 | $D_7I'T_3B_6K_6$                    | $SP \leftarrow SP - 1$                                       | Push AC onto the stack              |
|                                                     |      | $D_7I'T_4B_6K_6$                    | $AR \leftarrow SP$                                           |                                     |
|                                                     |      | $D_7I'T_5B_6K_6$                    | $M[AR] \leftarrow AC, SC \leftarrow 0$                       |                                     |
| SZAC                                                | 7047 | $rB_6K_7Z$                          | $PC \leftarrow PC + 1, SC \leftarrow 0$                      | Skip next instruction if AC zero    |
|                                                     |      | rB <sub>6</sub> K <sub>7</sub> Z'   | $SC \leftarrow 0$                                            |                                     |
| SNAC                                                | 7080 | $rB_7K_0S$                          | $PC \leftarrow PC + 1, SC \leftarrow 0$                      | Skip next instruction if AC         |
|                                                     |      | rB <sub>7</sub> K <sub>0</sub> S'   | $SC \leftarrow 0$                                            | negative                            |
| SPAC                                                | 7081 | rB <sub>7</sub> K <sub>1</sub> S'Z' | $PC \leftarrow PC + 1, SC \leftarrow 0$                      | Skip next instruction if AC         |
|                                                     |      | $rB_7K_1(S'Z')'$                    | $SC \leftarrow 0$                                            | positive                            |
| SSC                                                 | 7082 | $rB_7K_2C$                          | $PC \leftarrow PC + 1, SC \leftarrow 0$                      | Skip next instruction if C is set   |
|                                                     |      | rB <sub>7</sub> K <sub>2</sub> C'   | $SC \leftarrow 0$                                            |                                     |
| SCC                                                 | 7083 | rB <sub>7</sub> K <sub>3</sub> C'   | $PC \leftarrow PC + 1, SC \leftarrow 0$                      | Skip next instruction if C is clear |
|                                                     |      | rB <sub>7</sub> K <sub>3</sub> C    | $SC \leftarrow 0$                                            |                                     |
| ION                                                 | 7084 | $rB_7K_4$                           | $IEN \leftarrow 1, SC \leftarrow 0$                          | Interrupt on                        |
| IOF                                                 | 7085 | rB <sub>7</sub> K <sub>5</sub>      | IEN $\leftarrow$ 0, SC $\leftarrow$ 0                        | Interrupt off                       |



#### Interrupts

- R is an interrupt indicator flag
- request for I/O will interrupt uP
  - Int1=1 or Into=1
  - Both signals are externally generated.
  - Signals tie to two D f/fs.
  - At each clock cycle, status is updated.
- During instruction execution, flags will be check and R set or clear accordingly
- R is check before every instruction to determine if uP should go into interrupt cycle or not
- Interrupt vector address at location 1



#### Interrupt cycles

Set this flag

- Log the interrupt event during instruction cycle.
  - To' T1' T2' (IEN)( $\overline{INTo}+\overline{INT1}$ ): R  $\leftarrow$ 1
- Interrupt occurs asynchronously. Need to save
  - Return address
  - Status of current execution
    - Eg: interrupt occurs between an arithmetic instruction that set a flag and conditional jump instruction that acts on that flag.
  - Determine the interrupt vector address and branch to that address
  - Disable further interrupts (clear IEN flag).
    - User may re-enable the interrupt in the interrupt service routine.
- When R is set, go into interrupt acknowledgement cycle
  - RTo : SP←SP-1, TR←PC
  - RT<sub>1</sub> : AR  $\leftarrow$ SP
  - RT2 :  $M[AR] \leftarrow FLAGS$ ,  $SP \leftarrow SP-1$
  - RT<sub>3</sub> : AR  $\leftarrow$  SP, PC $\leftarrow$  o
  - RT<sub>4</sub> :  $M[AR] \leftarrow TR$ ,  $PC \leftarrow PC+1$ ,  $IEN \leftarrow o$ ,  $R \leftarrow o$ ,  $SC \leftarrow o$

Interrupt vector address is at location 1



#### Listing of all control functions and microoperations

| Fetch     | R'T0                    | : AR←PC                                                                                                |
|-----------|-------------------------|--------------------------------------------------------------------------------------------------------|
|           | R'T1                    | : IR←M[AR], PC←PC+1                                                                                    |
|           |                         |                                                                                                        |
| Decode    | R'T2                    | : D0,, D7 $\leftarrow$ Decode IR(12-14), AR $\leftarrow$ IR(0-11), I $\leftarrow$ IR(15)               |
|           |                         |                                                                                                        |
| Indirect  | D7'IT3                  | : AR←M[AR]                                                                                             |
|           |                         |                                                                                                        |
| Interrupt | T0'T1'T2'(IEN)(FGI+FGO) | : R←1                                                                                                  |
|           |                         |                                                                                                        |
| Interrupt | RT0                     | : SP←SP-1, TR←PC                                                                                       |
| decode    | RT1                     | : AR ←SP                                                                                               |
|           | RT2                     | : M[AR] $\leftarrow$ FLAGS, SP $\leftarrow$ SP-1                                                       |
|           | RT3                     | : AR←SP, PC←0                                                                                          |
|           | RT4                     | : M[AR] $\leftarrow$ TR, PC $\leftarrow$ PC+1, IEN $\leftarrow$ 0, R $\leftarrow$ 0, SC $\leftarrow$ 0 |
| 3.7       | D.C. I. (               | 11 \                                                                                                   |

Memory Reference Instruction (see table)

Register Reference Instruction (see table)

Initialization: Reset RS=1: clear all (RS=DF/F with D input connected to reset pin. As long as D is high, Q output will remain high.

#### Synthesizing the Control logic

- Signals for S<sub>3</sub>,S<sub>2</sub>, S<sub>1</sub> and So to select which of the 11 registers drive the bus
- Signals to control the inputs (LD,INR,CLR,DEC) of the 11 registers
- Signals to control the read and write inputs of memory
- Signals to set, clear, or complement the bit addressable FF
- Signals to control the ALU circuit

Interpreting RTL into logic gates

Load the content on the bus into AR.

When this condition occurs, perform the operation on the right.

RT1: AR ←SP

Content of SP to be placed on the bus.



#### Select which of the 10 registers drive the bus

| BUN       | $D_4T_4$                                                       | PC ← AR                  | X1: AR     |
|-----------|----------------------------------------------------------------|--------------------------|------------|
| CALL      | $D_5T_4$                                                       | TR ← AR                  |            |
| Fetch     | R'T <sub>0</sub>                                               | AR ← PC                  | X2: PC     |
| Interrupt | RT <sub>0</sub>                                                | TR ← PC                  |            |
| CALL      | $D_5T_6$                                                       | $M[AR] \leftarrow PC$    |            |
| DSZ       | $D_6T_6$                                                       | $M[AR] \leftarrow DR$    | X3: DR     |
| STA       | $D_3T_4$                                                       | $M[AR] \leftarrow AC$    | X4: AC     |
| PUSH      | $D_7I'T_5B_6K_6$                                               | $M[AR] \leftarrow AC$    |            |
| AC2SP     | rB <sub>6</sub> K <sub>0</sub>                                 | SP ← AC                  |            |
| Decode    | R'T <sub>2</sub>                                               | $AR \leftarrow IR(0-11)$ | X5: IR     |
| Interrupt | RT <sub>4</sub>                                                | M[AR]←TR                 | X6: TR     |
| CALL      | $D_5T_7$                                                       | PC ← TR                  |            |
| Fetch     | R'T <sub>1</sub>                                               | $IR \leftarrow M[AR]$    | X7: Memory |
| Indirect  | D <sub>7</sub> 'T <sub>3</sub>                                 | $AR \leftarrow M[AR]$    |            |
| LDB       | $D_0T_4$                                                       | $BP \leftarrow M[AR]$    |            |
| LDX       | $D_1T_4$                                                       | $XR \leftarrow M[AR]$    |            |
| LDA       | $D_2T_4$                                                       | $DR \leftarrow M[AR]$    |            |
| DSZ       | $D_6T_4$                                                       | $DR \leftarrow M[AR]$    |            |
| LDABP     | $D_7I'T_4B_6K_2$                                               | $DR \leftarrow M[AR]$    |            |
| IRET      | D <sub>7</sub> I' T <sub>4</sub> B <sub>6</sub> K <sub>3</sub> | $PC \leftarrow M[AR]$    |            |
| IRET      | D <sub>7</sub> I' T <sub>6</sub> B <sub>6</sub> K <sub>3</sub> | $FLAGS \leftarrow M[AR]$ |            |
| RET       | D <sub>7</sub> I' T <sub>4</sub> B <sub>6</sub> K <sub>4</sub> | $PC \leftarrow M[AR]$    |            |
| POP       | $D_7I' T_4B_6K_5$                                              | $DR \leftarrow M[AR]$    |            |

|             | X8=OR(            |             |            |
|-------------|-------------------|-------------|------------|
|             |                   |             |            |
| Interrupt   | RT <sub>1</sub>   | AR ← SP     | X8: SP     |
| Interrupt / | RT <sub>3</sub>   | AR ←SP      |            |
| CALL        | $D_5T_5$          | AR ← SP     |            |
| SP2BP       | $rB_6K_1$         | BP ← SP     |            |
| IRET        | $D_7I' T_3B_6K_3$ | AR ← SP     |            |
| IRET        | $D_7I' T_5B_6K_3$ | AR ←SP      |            |
| RET         | $D_7I'T_3B_6K_4$  | AR ← SP     |            |
| POP         | $D_7I' T_3B_6K_5$ | AR ← SP     |            |
| PUSH        | $D_7I'T_4B_6K$    | AR ← SP     |            |
| LDABP       | $D_7I'T_3B_6K_2$  | AR ← BP     | X9: BP     |
| Interrupt   | RT <sub>2</sub>   | M[AR]←FLAGS | X10: FLAGS |
| ADD         | $D_7I'T_3B_4K_2$  | DR←XR       | X11: XR    |
| ADC         | $D_7I' T_3B_4K_3$ | DR←XR       |            |
| SUB         | $D_7I' T_3B_4K_4$ | DR←XR       |            |
| SBB         | $D_7I' T_3B_4K_5$ | DR←XR       |            |
| AND         | $D_7I'T_3B_4K_6$  | DR←XR       |            |
| OR          | $D_7I' T_3B_4K_7$ | DR←XR       |            |
| XOR         | $D_7I' T_3B_5K_0$ | DR←XR       |            |



Control of common bus via S0,S1,S2,S3

| $\mathbf{x}_1$ | $\mathbf{x}_2$ | $\mathbf{x}_3$ | $\mathbf{x}_4$ | <b>x</b> <sub>5</sub> | <b>X</b> <sub>6</sub> | <b>X</b> <sub>7</sub> | <b>X</b> <sub>8</sub> | <b>X</b> <sub>9</sub> | _x <sub>10</sub> | <b>X</b> <sub>11</sub> | $S_3$ | $S_2$ | $S_1$ | $S_0$ |        |
|----------------|----------------|----------------|----------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|------------------|------------------------|-------|-------|-------|-------|--------|
| 0              | 0              | 0              | 0              | 0                     | 0                     | 0                     | 0                     | 0                     | 0                | 0                      | 0     | 0     | 0     | 0     | None   |
| 1              | 0              | 0              | 0              | 0                     | 0                     | 0                     | 0                     | 0                     | 0                | 0                      | 0     | 0     | 0     | 1     | AR     |
| 0              | 1              | 0              | 0              | 0                     | 0                     | 0                     | 0                     | 0                     | 0                | 0                      | 0     | 0     | 1     | 0     | PC     |
| 0              | 0              | 1              | 0              | 0                     | 0                     | 0                     | 0                     | 0                     | 0                | 0                      | 0     | 0     | 1     | 1     | DR     |
| 0              | 0              | 0              | 1              | 0                     | 0                     | 0                     | 0                     | 0                     | 0                | 0                      | 0     | 1     | 0     | 0     | AC     |
| 0              | 0              | 0              | 0              | 1                     | 0                     | 0                     | 0                     | 0                     | 0                | 0                      | 0     | 1     | 0     | 1     | IR     |
| 0              | 0              | 0              | 0              | 0                     | 1                     | 0                     | 0                     | 0                     | 0                | 0                      | 0     | 1     | 1     | 0     | TR     |
| 0              | 0              | 0              | 0              | 0                     | 0                     | 1                     | 0                     | 0                     | 0                | 0                      | 0     | 1     | 1     | 1     | MEMORY |
| 0              | 0              | 0              | 0              | 0                     | 0                     | 0                     | 1                     | 0                     | 0                | 0                      | 1     | 0     | 0     | 0     | SP     |
| 0              | 0              | 0              | 0              | 0                     | 0                     | 0                     | 0                     | 1                     | 0                | 0                      | 1     | 0     | 0     | 1     | BP     |
| 0              | 0              | 0              | 0              | 0                     | 0                     | 0                     | 0                     | 0                     | 1                | 0                      | 1     | 0     | 1     | 0     | FLAGS  |
| 0              | 0              | 0              | 0              | 0                     | 0                     | 0                     | 0                     | 0                     | 0                | 1                      | 1     | 0     | 1     | 0     | XR     |

- From table of control functions, pick out all functions requiring each register to drive bus
- Derive logic function for X
  - Xn=OR (corresponding conditions)
- Send Xn into a 16 to 4 encoder to derive So, S1, S2, S3.
- So, S1, S2, S3 are then used to drive the bus selectors.



| RET                                         | $D_7I'T_3B_6K_4$                                                                                                                                                                                                                                                                             | AR ← SP                                                                                                                                                                                                        |
|---------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IRET                                        | $D_7I'T_3B_6K_3$                                                                                                                                                                                                                                                                             | AR ← SP                                                                                                                                                                                                        |
| CALL                                        | $D_5T_5$                                                                                                                                                                                                                                                                                     | AR ← SP                                                                                                                                                                                                        |
| PUSH                                        | $D_7I'T_4B_6K_6$                                                                                                                                                                                                                                                                             | AR ← SP                                                                                                                                                                                                        |
| POP                                         | $D_7I'T_3B_6K_5$                                                                                                                                                                                                                                                                             | AR ← SP                                                                                                                                                                                                        |
| Interrupt                                   | RT <sub>3</sub>                                                                                                                                                                                                                                                                              | AR ← SP                                                                                                                                                                                                        |
| Interrupt                                   | RT <sub>1</sub>                                                                                                                                                                                                                                                                              | AR ← SP                                                                                                                                                                                                        |
| IRET                                        | $D_7I'T_5B_6K_3$                                                                                                                                                                                                                                                                             | AR ← SP                                                                                                                                                                                                        |
| Fetch                                       | R'T <sub>0</sub>                                                                                                                                                                                                                                                                             | AR ← PC                                                                                                                                                                                                        |
| LDABP                                       | $D_7I'T_3B_6K_2$                                                                                                                                                                                                                                                                             | AR ← BP                                                                                                                                                                                                        |
| Indirect                                    | $D_7$ ' $T_3$                                                                                                                                                                                                                                                                                | $AR \leftarrow M[AR]$                                                                                                                                                                                          |
| Decode                                      | R'T,                                                                                                                                                                                                                                                                                         | $AR \leftarrow IR(0-11)$                                                                                                                                                                                       |
|                                             | 2                                                                                                                                                                                                                                                                                            | ( )                                                                                                                                                                                                            |
| Interrupt                                   | RT <sub>3</sub>                                                                                                                                                                                                                                                                              | PC ← 0                                                                                                                                                                                                         |
| Interrupt Interrupt                         |                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                |
| -                                           | RT <sub>3</sub>                                                                                                                                                                                                                                                                              | PC ← 0                                                                                                                                                                                                         |
| Interrupt                                   | RT <sub>3</sub>                                                                                                                                                                                                                                                                              | $PC \leftarrow 0$ $PC \leftarrow PC+1$                                                                                                                                                                         |
| Interrupt SZAC                              | $RT_3$ $RT_4$ $rB_6K_7Z$                                                                                                                                                                                                                                                                     | $PC \leftarrow 0$ $PC \leftarrow PC+1$ $PC \leftarrow PC+1$                                                                                                                                                    |
| Interrupt SZAC SPAC                         | $RT_{3}$ $RT_{4}$ $rB_{6}K_{7}Z$ $rB_{7}K_{1}S'Z'$                                                                                                                                                                                                                                           | $PC \leftarrow 0$ $PC \leftarrow PC+1$ $PC \leftarrow PC+1$ $PC \leftarrow PC+1$                                                                                                                               |
| Interrupt SZAC SPAC SNAC                    | $RT_{3}$ $RT_{4}$ $rB_{6}K_{7}Z$ $rB_{7}K_{1}S'Z'$ $rB_{7}K_{0}S$                                                                                                                                                                                                                            | $PC \leftarrow 0$ $PC \leftarrow PC+1$ $PC \leftarrow PC+1$ $PC \leftarrow PC+1$ $PC \leftarrow PC+1$                                                                                                          |
| Interrupt SZAC SPAC SNAC SCC                | $RT_{3}$ $RT_{4}$ $rB_{6}K_{7}Z$ $rB_{7}K_{1}S'Z'$ $rB_{7}K_{0}S$ $rB_{7}K_{3}C'$                                                                                                                                                                                                            | $PC \leftarrow 0$ $PC \leftarrow PC+1$                                                                                     |
| Interrupt SZAC SPAC SNAC SCC DSZ            | $RT_{3}$ $RT_{4}$ $rB_{6}K_{7}Z$ $rB_{7}K_{1}S'Z'$ $rB_{7}K_{0}S$ $rB_{7}K_{3}C'$ $D_{6}T_{6}Y$                                                                                                                                                                                              | $PC \leftarrow 0$ $PC \leftarrow PC+1$                                                                |
| Interrupt SZAC SPAC SNAC SCC DSZ Fetch      | RT <sub>3</sub> RT <sub>4</sub> rB <sub>6</sub> K <sub>7</sub> Z  rB <sub>7</sub> K <sub>1</sub> S'Z'  rB <sub>7</sub> K <sub>0</sub> S  rB <sub>7</sub> K <sub>3</sub> C'  D <sub>6</sub> T <sub>6</sub> Y  R'T <sub>1</sub>                                                                | $PC \leftarrow 0$ $PC \leftarrow PC+1$                                           |
| Interrupt SZAC SPAC SNAC SCC DSZ Fetch IRET | RT <sub>3</sub> RT <sub>4</sub> rB <sub>6</sub> K <sub>7</sub> Z  rB <sub>7</sub> K <sub>1</sub> S'Z'  rB <sub>7</sub> K <sub>0</sub> S  rB <sub>7</sub> K <sub>3</sub> C'  D <sub>6</sub> T <sub>6</sub> Y  R'T <sub>1</sub> D <sub>7</sub> I' T <sub>4</sub> B <sub>6</sub> K <sub>3</sub> | $PC \leftarrow 0$ $PC \leftarrow PC+1$ |

# Signals to control the (LD,INR,CLR,DEC) of the 11 registers

**CLR**PC=**RT**4∨ reset

INRPC=OR(...)

 $LD_{PC} = OR(...)$ 

Group all records with PC on the left. Implies that under the conditions, PC is to be changed accordingly.

| PUSH      | $D_7I'T_5B_6K_6$ | $M[AR] \leftarrow AC$  |
|-----------|------------------|------------------------|
| STA       | $D_3T_4$         | $M[AR] \leftarrow AC$  |
| Interrupt | RT <sub>4</sub>  | M[AR] ←TR              |
| Interrupt | RT <sub>2</sub>  | M[AR] ←FLAGS           |
| CALL      | $D_5T_6$         | $M[AR] \leftarrow PC$  |
| DSZ       | $D_6T_6$         | $M[AR] \leftarrow DR$  |
| Interrupt | $RT_0$           | TR ← PC                |
| CALL      | $D_5T_4$         | TR ← AR                |
| LDX       | $D_1T_4$         | $XR \leftarrow M[AR]$  |
| DSZ       | $D_6T_5$         | $DR \leftarrow DR - 1$ |
| LDABP     | $D_7I'T_4B_6K_2$ | $DR \leftarrow M[AR]$  |
| POP       | $D_7I'T_4B_6K_5$ | $DR \leftarrow M[AR]$  |
| LDA       | $D_2T_4$         | $DR \leftarrow M[AR]$  |
| DSZ       | $D_6T_4$         | $DR \leftarrow M[AR]$  |
| XOR       | $D_7I'T_3B_5K_0$ | DR←XR                  |
| ADD       | $D_7I'T_3B_4K_2$ | DR←XR                  |
| ADC       | $D_7I'T_3B_4K_3$ | DR←XR                  |
| SBB       | $D_7I'T_3B_4K_5$ | DR←XR                  |
| SUB       | $D_7I'T_3B_4K_4$ | DR←XR                  |
| AND       | $D_7I'T_3B_4K_6$ | DR←XR                  |
| OR        | $D_7I'T_3B_4K_7$ | DR←XR                  |

## More controls

| CALL      | $D_5T_4$                       | $SP \leftarrow SP - 1$   |
|-----------|--------------------------------|--------------------------|
| PUSH      | $D_7I'T_3B_6K_6$               | $SP \leftarrow SP - 1$   |
| Interrupt | RT <sub>2</sub>                | $SP \leftarrow SP - 1$   |
| Interrupt | $RT_0$                         | $SP \leftarrow SP - 1$   |
| RET       | $D_7I'T_4B_6K_4$               | $SP \leftarrow SP + 1$   |
| IRET      | $D_7I'T_4B_6K_3$               | $SP \leftarrow SP + 1$   |
| IRET      | $D_7I'T_6B_6K_3$               | $SP \leftarrow SP + 1$   |
| POP       | $D_7I'T_4B_6K_5$               | $SP \leftarrow SP + 1$   |
| AC2SP     | $rB_6K_0$                      | SP ← AC                  |
| SP2BP     | rB <sub>6</sub> K <sub>1</sub> | BP ← SP                  |
| LDB       | $D_0T_4$                       | $BP \leftarrow M[AR]$    |
| Fetch     | R'T <sub>1</sub>               | $IR \leftarrow M[AR]$    |
| IRET      | $D_7I'T_6B_6K_3$               | $FLAGS \leftarrow M[AR]$ |



## Logic for control of F/F

| CLC       | $rB_5K_5$                      | $C \leftarrow 0$   |
|-----------|--------------------------------|--------------------|
| CMC       | $rB_8K_6$                      | C ← C'             |
| STC       | $rB_5K_7$                      | C ← 1              |
| IRET      | $D_7I'T_6B_6K_3$               | IEN ← 1            |
| ION       | rB <sub>7</sub> K <sub>4</sub> | IEN ← 1            |
| IOF       | rB <sub>7</sub> K <sub>5</sub> | $IEN \leftarrow 0$ |
| Interrupt | RT <sub>4</sub>                | $IEN \leftarrow 0$ |
| Interrupt | RT <sub>4</sub>                | R ← 0              |
| Interrupt | T0'T1'T2'(IEN(FGI<br>+FGO)     | R ← 1              |
| Decode    | R'T <sub>2</sub>               | I ← IR(15)         |

#### Link to ALU. To be considered with ALU design



Circuit for IEN F/F

## Completing the picture for the F/F

| SHR       | rB <sub>5</sub> K <sub>1</sub>                                 | SC ← 0            |
|-----------|----------------------------------------------------------------|-------------------|
| SHL       | $rB_5K_2$                                                      | SC ← 0            |
| CLAC      | rB <sub>5</sub> K <sub>3</sub>                                 | SC ← 0            |
| IRET      | D <sub>7</sub> I' T <sub>6</sub> B <sub>6</sub> K <sub>3</sub> | SC ← 0            |
| LDABP     | $D_7I'T_5B_6K_2$                                               | SC ← 0            |
| CMAC      | $rB_5K_4$                                                      | $SC \leftarrow 0$ |
| CLC       | $rB_5K_5$                                                      | SC ← 0            |
| CMC       | $rB_8K_6$                                                      | $SC \leftarrow 0$ |
| STC       | $rB_5K_7$                                                      | $SC \leftarrow 0$ |
| AC2SP     | $rB_6K_0$                                                      | $SC \leftarrow 0$ |
| SP2BP     | rB <sub>6</sub> K <sub>1</sub>                                 | $SC \leftarrow 0$ |
| BUN       | $D_4T_4$                                                       | SC ← 0            |
| LDA       | $D_2T_5$                                                       | $SC \leftarrow 0$ |
| LDB       | $D_0T_4$                                                       | $SC \leftarrow 0$ |
| LDX       | $D_1T_4$                                                       | $SC \leftarrow 0$ |
| Interrupt | RT <sub>4</sub>                                                | SC←0              |
| CALL      | $D_5T_7$                                                       | SC ← 0            |
| DSZ       | $D_6T_6$                                                       | SC ← 0            |
| INC       | $rB_4K_0$                                                      | SC ← 0            |
| DEC       | $rB_4K_1$                                                      | SC ← 0            |
| ADD       | $D_7I'T_4B_4K_2$                                               | SC ← 0            |
| STA       | $D_3T_4$                                                       | SC ← 0            |

| RET  | $D_7I'$ $T_4B_6K_4$               | SC ← 0 |
|------|-----------------------------------|--------|
| IOF  | rB <sub>7</sub> K <sub>5</sub>    | SC ← 0 |
| ION  | rB <sub>7</sub> K <sub>4</sub>    | SC ← 0 |
| SCC  | rB <sub>7</sub> K <sub>3</sub> C' | SC ← 0 |
| SCC  | rB <sub>7</sub> K <sub>3</sub> C  | SC ← 0 |
| SPAC | rB <sub>7</sub> K <sub>1</sub>    | SC ← 0 |
| SNAC | $rB_7K_0$                         | SC ← 0 |
| SZAC | rB <sub>6</sub> K <sub>7</sub>    | SC ← 0 |
| PUSH | $D_7I'T_5B_6K_6$                  | SC ← 0 |
| POP  | $D_7I' T_4B_7K_5$                 | SC ← 0 |
| SUB  | $D_7I' T_4B_4K_4$                 | SC ← 0 |
| ADC  | $D_7I' T_4B_4K_3$                 | SC ← 0 |
| XOR  | $D_7I' T_4B_5K_0$                 | SC ← 0 |
| OR   | $D_7I' T_4B_4K_7$                 | SC ← 0 |
| AND  | $D_7I' T_4B_4K_6$                 | SC ← 0 |
| SBB  | $D_7I' T_4B_4K_5$                 | SC ← 0 |

#### The ALU and the accumulator

| CLAC  | rD V                           | AC ← 0                                                                         |
|-------|--------------------------------|--------------------------------------------------------------------------------|
|       | rB <sub>5</sub> K <sub>3</sub> |                                                                                |
| LDABP | $D_7I'T_3B_6K_2$               | $AC \leftarrow 0$                                                              |
| POP   | $D_7I'T_3B_6K_5$               | AC ← 0                                                                         |
| LDA   | $D_2T_4$                       | $AC \leftarrow 0$                                                              |
| LDABP | $D_7I'T_5B_6K_2$               | AC ← AC + DR                                                                   |
| POP   | $D_7I'T_4B_7K_5$               | $AC \leftarrow AC + DR$                                                        |
| ADD   | $D_7I'T_4B_4K_2$               | $AC \leftarrow AC + DR$                                                        |
| LDA   | $D_2T_5$                       | $AC \leftarrow AC + DR$                                                        |
| INC   | $rB_4K_0$                      | $AC \leftarrow AC + 1$                                                         |
| DEC   | rB <sub>4</sub> K <sub>1</sub> | AC ← AC - 1                                                                    |
| ADC   | $D_7I'T_4B_4K_3$               | $AC \leftarrow AC + DR + C$                                                    |
| SBB   | $D_7I'T_4B_4K_5$               | $AC \leftarrow AC - DR + C$                                                    |
| SUB   | $D_7I'T_4B_4K_4$               | $AC \leftarrow AC - DR$                                                        |
| AND   | $D_7I'T_4B_4K_6$               | $AC \leftarrow AC \wedge DR$                                                   |
| OR    | $D_7I'T_4B_4K_7$               | $AC \leftarrow AC \lor DR$                                                     |
| XOR   | $D_7I'T_4B_5K_0$               | $AC \leftarrow AC \oplus DR$                                                   |
| SHR   | rB <sub>5</sub> K <sub>1</sub> | $AC \leftarrow \operatorname{shr} AC, AC(15) \leftarrow C, C \leftarrow AC(0)$ |
| SHL   | $rB_5K_2$                      | $AC \leftarrow \text{shl } AC, AC(0) \leftarrow C, C \leftarrow AC(15)$        |
| CMAC  | rB <sub>5</sub> K <sub>4</sub> | AC ← AC'                                                                       |

We have not seen this.
However before we go on to interpret this, we need to look at the design of the ALU.

### Summary so far

- Derive the control logic in RTL format
  - To allow us to move data around on the local bus that we have created in according to the step needed to execute an instruction.
  - Produce the signal to select the ALU at the appropriate time
    - Signal to start the arithmetic/logic operation
    - Get the operands into the correct location
- Next
  - Look into the design of the ALU
  - The connection of the signal to the ALU

## Implementation of arithmetic operations







## Arithmetic micro-operations

- A combination of the previous elementary circuits
  - add, adc, sub, sbb, inc, dec



### **Arithmetic Circuit Function Table**

| Select |       |              |                |                             |                      |  |
|--------|-------|--------------|----------------|-----------------------------|----------------------|--|
| $S_1$  | $S_0$ | $C_{\rm in}$ | Input<br>Y     | Output $D = A + Y + C_{in}$ | Microoperation       |  |
| 0      | 0     | 0            | В              | D = A + B                   | Add                  |  |
| 0      | 0     | 1            | В              | D = A + B + 1               | Add with carry       |  |
| 0      | 1     | 0            | $\overline{B}$ | $D = A + \overline{B}$      | Subtract with borrow |  |
| 0      | 1     | 1            | $\overline{B}$ | $D = A + \overline{B} + 1$  | Subtract             |  |
| 1      | 0     | 0            | 0              | D = A                       | Transfer A           |  |
| 1      | 0     | 1            | 0              | D = A + 1                   | Increment A          |  |
| 1      | 1     | 0            | 1              | D = A - 1                   | Decrement A          |  |
| 1      | 1     | 1            | 1              | D = A                       | Transfer A           |  |



## Implementation of logic micro-operations

One stage of logic circuit





## Shift micro-operations

Shift Microoperations

| Symbolic designation                                                                                                                                                            | Description                                                                                                                                                                                            |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $R \leftarrow \text{shl } R$ $R \leftarrow \text{shr } R$ $R \leftarrow \text{cil } R$ $R \leftarrow \text{cir } R$ $R \leftarrow \text{ashl } R$ $R \leftarrow \text{ashr } R$ | Shift-left register <i>R</i> Shift-right register <i>R</i> Circular shift-left register <i>R</i> Circular shift-right register <i>R</i> Arithmetic shift-left <i>R</i> Arithmetic shift-right <i>R</i> |





| runction table |       |       |       |       |  |
|----------------|-------|-------|-------|-------|--|
| Select         |       | Outp  | out   |       |  |
| S              | $H_0$ | $H_1$ | $H_2$ | $H_3$ |  |
| 0              | $I_R$ | $A_0$ | $A_1$ | $A_2$ |  |
| 1              | $A_1$ | $A_2$ | $A_3$ | $I_L$ |  |

Function table

4-bit combinational circuit shifter.



## Arithmetic logic shift micro-operations

| S3 | S2 | S1 | S0 | Operation | Function |
|----|----|----|----|-----------|----------|
| 0  | 0  | 0  | 0  | F=A+1     | INC      |
| 0  | 0  | 0  | 1  | F=A+B+Cin | ADD      |
| 0  | 0  | 1  | 0  | F=A-B+Cin | SUB      |
| 0  | 0  | 1  | 1  | F=A-1     | DEC      |
| 0  | 1  | 0  | 0  | F=A∧B     | AND      |
| 0  | 1  | 0  | 1  | F=A∨B     | OR       |
| 0  | 1  | 1  | 0  | F=A⊕B     | XOR      |
| 0  | 1  | 1  | 1  | F=A'      | COM      |
| 1  | 0  | X  | X  | F=shr A   | SHR      |
| 1  | 1  | X  | X  | F=shl A   | SHL      |

**DR** register

Accumulator



#### The ALU and the accumulator

| CLAC  | rB <sub>5</sub> K <sub>3</sub> | AC ← 0                                                                           |
|-------|--------------------------------|----------------------------------------------------------------------------------|
| LDABP | $D_7I'T_3B_6K_2$               | AC ← 0                                                                           |
| POP   | $D_7I'T_3B_6K_5$               | AC ← 0                                                                           |
| LDA   | $D_2T_4$                       | AC ← 0                                                                           |
| INC   | $rB_4K_0$                      | $AC \leftarrow AC + 1$                                                           |
| ADC   | $D_7I'T_4B_4K_3$               | $AC \leftarrow AC + DR + C$                                                      |
| LDABP | $D_7I'T_5B_6K_2$               | $AC \leftarrow AC + DR + 0$                                                      |
| POP   | $D_7I'T_4B_7K_5$               | $AC \leftarrow AC + DR + 0$                                                      |
| ADD   | $D_7I'T_4B_4K_2$               | $AC \leftarrow AC + DR + \theta$                                                 |
| LDA   | $D_2T_5$                       | $AC \leftarrow AC + DR + 0$                                                      |
| SBB   | $D_7I'T_4B_4K_5$               | $AC \leftarrow AC - DR + C$                                                      |
| SUB   | $D_7I'T_4B_4K_4$               | $AC \leftarrow AC - DR + 0$                                                      |
| DEC   | rB <sub>4</sub> K <sub>1</sub> | AC ← AC-1                                                                        |
| AND   | $D_7I'T_4B_4K_6$               | $AC \leftarrow AC \wedge DR$                                                     |
| OR    | $D_7I'T_4B_4K_7$               | $AC \leftarrow AC \lor DR$                                                       |
| XOR   | $D_7I'T_4B_5K_0$               | $AC \leftarrow AC \oplus DR$                                                     |
| CMAC  | rB <sub>5</sub> K <sub>4</sub> | AC ← AC'                                                                         |
| SHR   | rB <sub>5</sub> K <sub>1</sub> | $AC \leftarrow \text{shr } AC$ ,<br>$AC(15) \leftarrow C$ , $C \leftarrow AC(0)$ |
| SHL   | rB <sub>5</sub> K <sub>2</sub> | $AC \leftarrow \text{shl } AC,$<br>$AC(0) \leftarrow C, C \leftarrow AC(15)$     |

 $AC_{clr} = OR(...)$ 

**Decoding Table** 

N<sub>0</sub>

N1=OR( ... )

N2=OR( ...)

**N3** 

**N4** 

N5

**N6** 

N7

**N8** 

N12

| S3 | S2 | S1 | S0 |     |
|----|----|----|----|-----|
| 0  | 0  | 0  | 0  | N0  |
|    | 0  | 0  | 1  | N1  |
|    | 0  | 1  | 0  | N2  |
| 0  | 0  | 1  | 1  | N3  |
| 0  | 1  | 0  | 0  | N4  |
| 0  | 1  | 0  | 1  | N5  |
| 0  | 1  | 1  | 0  | N6  |
| 0  | 1  | 1  | 1  | N7  |
| 1  | 0  | X  | X  | N8  |
| 1  | 1  | X  | X  | N12 |

#### ALU and Accumulator logic



| Condition                                  | Qk+1 | J | K |
|--------------------------------------------|------|---|---|
| rB5K5                                      | 0    | 0 | 1 |
| rB8K6                                      | Qk'  | 1 | 1 |
| rB5K7                                      | 1    | 1 | 0 |
| $(N0 \lor N1 \lor N2 \lor N3) \land Cout$  | 1    | 1 | 0 |
| $(N0 \lor N1 \lor N2 \lor N3) \land Cout'$ | 0    | 0 | 1 |
| $N8 \wedge AC(0)$                          | 1    | 1 | 0 |
| N8 ∧ AC(0)'                                | 0    | 0 | 1 |
| N9 ∧ AC(15)                                | 1    | 1 | 0 |
| N9 ∧ AC(15)'                               | 0    | 0 | 1 |
| NOR( above conditions)                     | Qk   | 0 | 0 |

g F/F



The logic for J and K input can now be derive using a sum of product or a product of sum method.

You have the logical design. Now it is a matter of coding them into VHDL/Verilog and then go through the placement and routing process.

## **General Specification of CPUs**

## General Specification of CPUs

- General register organization
- Stack organization
- Instruction formats
- Addressing modes
- Data transfer and manipulation
- Program control
- Reduced instruction set computer



Major components of CPU

#### General register

### organization

- Registers for intermediate results
  - bus interconnection
  - eg:  $R_1 \leftarrow R_2 + R_3$
- 1. MUX A selector (SELA): to place the content of R2 into bus A.
- 2. MUX B selector (SELB): to place the content of R<sub>3</sub> into bus B.
- 3. ALU operation selector (OPR): to provide the arithmetic addition A + B.
- 4. Decoder destination selector (SELD): to transfer the content of the output bus into R1.
  - Activated by control word





#### Control word

| 3    | 3    | 3    | 5   |
|------|------|------|-----|
| SELA | SELB | SELD | OPR |

#### **Encoding of register selection fields**

| Binary<br>Code | SELA  | SELB       | SELD |
|----------------|-------|------------|------|
| 000            | Input | Input      | None |
| 001            | R1    | Ř1         | R1   |
| 010            | R2    | R2         | R2   |
| 011            | R3    | R3         | R3   |
| 100            | R4    | R4         | R4   |
| 101            | R5    | <i>R</i> 5 | R5   |
| 110            | R6    | R6         | R6   |
| 111            | R7    | R7         | R7   |

#### **Encoding of ALU operations**

| OPR<br>Select | Operation        | Symbol |
|---------------|------------------|--------|
| 00000         | Transfer A       | TSFA   |
| 00001         | Increment A      | INCA   |
| 00010         | $Add\ A + B$     | ADD    |
| 00101         | Subtract $A - B$ | SUB    |
| 00110         | Decrement A      | DECA   |
| 01000         | AND $A$ and $B$  | AND    |
| 01010         | OR A and B       | OR     |
| 01100         | XOR A and $B$    | XOR    |
| 01110         | Complement A     | COMA   |
| 10000         | Shift right A    | SHRA   |
| 11000         | Shift left A     | SHLA   |



#### LIFO

## Stack Organization

- Typical for temporary storage of variables/parameters
- 2 operations
  - push (for registers)
    - SP←SP+1
    - $M[SP] \leftarrow DR$
    - if (SP=o) then (FULL  $\leftarrow$ 1)
    - EMTY ←o
  - pop (for registers)
    - DR  $\leftarrow$  M[SP]
    - SP←SP-1
    - if (SP=o) then (EMTY  $\leftarrow$ 1)
    - FULL ←o
- type
  - registers
  - memory
    - normally do not provide checks for overflows
    - normally grows downwards

#### 64 word stack registers



## Reverse polish notation

• Notation:

• Infix: A+B RPN: AB+

• infix: (A+B)\*[C\*(D+E)+F] RPN:AB+DE+C\*F+\*

Effective for arithmetic notation

any arithmetic expression can be expressed in parentheses-free polish notation

• ideal for stack implementation



## CPU organisation: 3 types

- Single accumulator organisation
  - all instruction performed with an implied accumulator
    - ADD X
- General register organisation
  - will require in general 3 register specification
    - ADD R<sub>1</sub>, R<sub>2</sub>, R<sub>3</sub>,  $R_1 \leftarrow R_2 + R_3$
  - or 2 register specification, if destination is same as one of the source
    - ADD R2, R3,  $R2 \leftarrow R2 + R3$
- Stack organisation
  - as discussed before where the main instruction is the PUSH
  - no need for address field
    - ADD
    - the operands are pop off the stack, result are push back automatically on to the stack as well



#### Instruction formats

X=(A+B)\*(C+D)

#### Three address instruction

| ADD | R1, A, B  | $R1 \leftarrow M[A] + M[B]$ |
|-----|-----------|-----------------------------|
| ADD | R2, C, D  | $R2 \leftarrow M[C] + M[D]$ |
| MUL | X, R1, R2 | $M[X] \leftarrow R1 * R2$   |

#### One address instruction

| LOAD  | A       | $AC \leftarrow M[A]$      |
|-------|---------|---------------------------|
| ADD   | В       | $AC \leftarrow AC + M[B]$ |
| STORE | ${f T}$ | $M[T] \leftarrow AC$      |
| LOAD  | С       | $AC \leftarrow M[C]$      |
| ADD   | D       | $AC \leftarrow AC + M[D]$ |
| MUL   | ${f T}$ | $AC \leftarrow AC * M[T]$ |
| STORE | X       | $M[X] \leftarrow AC$      |
|       |         |                           |

#### Two address instruction

| MOV | R1, A | $R1 \leftarrow M[A]$      |
|-----|-------|---------------------------|
| ADD | R1, B | $R1 \leftarrow R1 + M[B]$ |
| VOM | R2, C | R2←M[C]                   |
| ADD | R2, D | R2←R2+M[D]                |
| MUL | R1,R2 | R1 ← R1 * R2 1            |
| MOV | X, R1 | $M[X] \leftarrow R1$      |

#### Zero address instruction

| PUSH | A | TOS ← A                            |
|------|---|------------------------------------|
| PUSH | В | TOS←B                              |
| ADD  |   | $TOS \leftarrow (A + B)$           |
| PUSH | С | TOS←C                              |
| PUSH | D | TOS ← D                            |
| ADD  |   | $TOS \leftarrow (C + D)$           |
| MUL  |   | $TOS \leftarrow (C + D) * (A + B)$ |
| POP  | X | $M[X] \leftarrow TOS$              |
|      |   |                                    |



#### RISC instructions

- Load-store architecture:
  - Use of only load and store instructions only to access memory
- All other instructions are register type
- Simplifies decoding allow less work to be done in a clock cycle
  - Leads to better potential for higher frequency operation.

$$X=(A+B)*(C+D)$$

|       | R1, A<br>R2, B<br>R3, C<br>R4, D<br>R1, R1, R2 | $R1 \leftarrow M[A]$ $R2 \leftarrow M[B]$ $R3 \leftarrow M[C]$ $R4 \leftarrow M[D]$ $R1 \leftarrow R1 + R2$ |
|-------|------------------------------------------------|-------------------------------------------------------------------------------------------------------------|
|       | -                                              |                                                                                                             |
| _     | -                                              |                                                                                                             |
| ADD   | R3, R3, R2                                     | R3 + R3 + R2                                                                                                |
| MUL   | R1, R1, R3                                     | $R1 \leftarrow R1 * R3$                                                                                     |
| STORE | X, R1                                          | $M[X] \leftarrow R1$                                                                                        |

## Addressing modes

- To give programming versatility
- to reduce the number of bits in the addressing field of the instruction
- The various modes
  - Implied mode
  - Immediate mode
  - Register mode
  - Register indirect mode
  - Autoincrement or autodecrement mode
  - Direct address mode
  - Indirect address mode
  - Relative address mode
  - Indexed addressing mode
  - Base register addressing mode



### Classification of instructions

- Data transfer instructions
- Data manipulation instructions
- Program control instructions



## Data transfer instructions

**Typical data transfer instructions** 

Recommended assembly language convention

| Mode              | Assembly Convention | Register Transfer                         |
|-------------------|---------------------|-------------------------------------------|
| Direct address    | LD ADR              | $AC \leftarrow M[ADR]$                    |
| Indirect address  | LD @ADR             | $AC \leftarrow M[M[ADR]]$                 |
| Relative address  | LD \$ADR            | $AC \leftarrow M[PC + ADR]$               |
| Immediate operand | LD #NBR             | $AC \leftarrow NBR$                       |
| Index addressing  | LD ADR(X)           | $AC \leftarrow M[ADR + XR]$               |
| Register          | LD R1               | $AC \longleftarrow R1$                    |
| Register indirect | LD (R1)             | $AC \longleftarrow M[R1]$                 |
| Autoincrement     | LD (R1)+            | $AC \leftarrow M[R1], R1 \leftarrow R1 +$ |

| Name     | Mnemonic |
|----------|----------|
| Load     | LD       |
| Store    | ST       |
| Move     | MOV      |
| Exchange | XCH      |
| Input    | IN       |
| Output   | OUT      |
| Push     | PUSH     |
| Pop      | POP      |
|          |          |

Various addressing modes



## manipulation instructions

**TABLE 8-8** Typical Logical and Bit Manipulation Instructions

| Name              | Мпетопіс |
|-------------------|----------|
| Clear             | CLR      |
| Complement        | COM      |
| AND               | AND      |
| OR                | OR       |
| Exclusive-OR      | XOR      |
| Clear carry       | CLRC     |
| Set carry         | SETC     |
| Complement carry  | COMC     |
| Enable interrupt  | EI       |
| Disable interrupt | DI       |

TABLE 8-7 Typical Arithmetic Instructions

| Name                    | Mnemonic |
|-------------------------|----------|
| Increment               | INC      |
| Decrement               | DEC      |
| Add                     | ADD      |
| Subtract                | SUB      |
| Multiply                | MUL      |
| Divide                  | DIV      |
| Add with carry          | ADDC     |
| Subtract with borrow    | SUBB     |
| Negate (2's complement) | NEG      |

**TABLE 8-9** Typical Shift Instructions

| Name                       | Mnemonic       |
|----------------------------|----------------|
| Logical shift right        | SHR            |
| Logical shift left         | $\mathbf{SHL}$ |
| Arithmetic shift right     | SHRA           |
| Arithmetic shift left      | SHLA           |
| Rotate right               | ROR            |
| Rotate left                | ROL            |
| Rotate right through carry | RORC           |
| Rotate left through carry  | ROLC           |



## Program control

Typical Program Control Instructions

| Name                     | Mnemonic |
|--------------------------|----------|
| Branch                   | BR       |
| Jump                     | JMP      |
| Skip                     | SKP      |
| Call                     | CALL     |
| Return                   | RET      |
| Compare (by subtraction) | CMP      |
| Test (by ANDing)         | TST      |



Status register bits.

A: 11110000

 $\overline{B}$  + 1: +11101100

A - B: 11011100

C=1 S=1 V=0 Z=0

# Conditional branch instructions

| Mnemonic                            | Branch condition             | Tested condition |  |  |
|-------------------------------------|------------------------------|------------------|--|--|
| BZ                                  | Branch if zero               | Z=1              |  |  |
| BNZ                                 | Branch if not zero           | Z = 0            |  |  |
| BC                                  | Branch if carry              | C = 1            |  |  |
| BNC                                 | Branch if no carry           | C = 0            |  |  |
| BP                                  | Branch if plus               | S = 0            |  |  |
| BM                                  | Branch if minus              | S = 1            |  |  |
| вv                                  | Branch if overflow           | V = 1            |  |  |
| BNV                                 | Branch if no overflow        | V = 0            |  |  |
| Unsigned                            | compare conditions $(A - B)$ |                  |  |  |
| BHI                                 | Branch if higher             | A > B            |  |  |
| BHE                                 | Branch if higher or equal    | $A \geq B$       |  |  |
| BLO                                 | Branch if lower              | A < B            |  |  |
| BLOE                                | Branch if lower or equal     | $A \leq B$       |  |  |
| BE                                  | Branch if equal              | A = B            |  |  |
| BNE                                 | Branch if not equal          | $A \neq B$       |  |  |
| Signed compare conditions $(A - B)$ |                              |                  |  |  |
| BGT                                 | Branch if greater than       | A > B            |  |  |
| BGE                                 | Branch if greater or equal   | $A \geq B$       |  |  |
| BLT                                 | Branch if less than          | A < B            |  |  |
| BLE                                 | Branch if less or equal      | $A \leq B$       |  |  |
| BE                                  | Branch if equal              | A = B            |  |  |
| BNE                                 | Branch if not equal          | $A \neq B$       |  |  |